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ABSTRACT 

This  paper  focuses  on  some  alternatives  with  respect  to 
a  DBMS  in  terms  of  a  centralized  versus  decentralized  environ¬ 
ment.  The  first  section  deals  with  the  concepts  and  tradeoffs 
involved  in  the  two  alternatives.  The  second  section  deals 
with  problems  in  distributed  DBMS,  such  as  deadlock,  rollback 
and  recovery,  data  conversion,  communications  and  operating 


systems  support. 
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T.  INTRODUCTION 

As  the  computer  Industry  has  grown  In  experience  and  application, 
there  Is  an  area  which  has  received  much  attention;  that  Is,  the  area  of 
managing,  organizing  and  storing  data.  Problems  of  reliability,  security 
and  timeliness  with  data  have  dram  almost  every  computer  user's  attention. 
Since  the  late  60 's,  there  has  been  a  growing  interest  in  providing 
software  which  separates  (at  a  cost)  the  manipulation  aspect  from  usual 
organizational  and  accounting  functions  found  In  a  normal  program.  Such 
"housekeeping"  chores  can  require  significant  efforts  on  the  part  of 
programmers.  Further,  once  such  chores  are  initially  done  they  will 
have  to  be  redone  time  and  again,  since  requirements  and  usage  will 
change . 

With  the  advent  of  Data  Base  Management  Systems  (DBMS)  and  assoc¬ 
iated  facilities  (Data  dictionaries,  query  languages,  report  writers, 
etc.)  the  task  of  data  organization,  management,  and  storage  has  been 
given  to  a  select  group  of  specialists.  These  specialists  (the  Data 
Base  Administrators  (DBA)  provide  the  necessary  control,  logging,  and 
access  information  and  software  to  the  program.  Such  activity  relieves 
the  programmers  of  this  overhead  function  allowing  them  to  concentrate 
on  the  necessary  manipulations. 

This  paper  focuses  on  some  alternatives  with  respect  to  a  DBMS 
in  terms  of  a  centralized  versus  decentralized  environment.  The  first 
section  of  this  paper  deals  with  the  concepts  and  tradeoffs  involved 
in  considering  the  two  environments.  The  second  section  of  the  paper 
then  deals  with  problems  which  are  encountered  in  a  distributed  data 
base  management  system.  These  problems  include  deadlock,  rollback 
and  recovery,  data  conversion',  redundancy,  and  communication  and  oper- 
atlng  system  requirements  for  effective  distribution. 
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XI.  THE  DBMS 

If  the  total  data  processing  application  of  an  organization  is  a 
payroll,  which  is  a  sequential  operation,  then  there  is  good  reason  not 
to  acquire  a  DBMS.  However,  if  data  is  accessed  randomly,  and/or  each 
separate  department  maintains  its  own  copy  and  Version  and  any  one  of  a 
number  of  other  problems  exists,  then  a  DBMS  may  be  of  some  use.  At 
least  a  new  dimension  of  problems  will  be  introduced,  hopefully  at  the 
expenses  of  a  far  larger  number  of  problems. 

DBMS  systems  support  essentially  four  different  structures: 

Network,  Hierarchical,  Inverted,  and  Relational  (no  fully  relational  com¬ 
mercial  DBMS  is  available  yet).  Each  of  the  techniques  has  its  own  advan¬ 
tages  and  disadvantages  which  are  not  discussed  further  here,  although 
careful  study  is  required  before  acquiring  a  DBMS. 

The  DBMS  will  require  from  minimal  to  significant  machine  resources. 
It  can  Increase  file  sir-'  requirements,  slow  processing,  require  addi¬ 
tional  manpower  resources,  and  be  of  a  significant  east.  However,  through 
lea  use  resources  can  be  released,  data  more  accurately  controlled,  pro¬ 
grams  developed  more  quickly,  and  the  continual  raoft&lflcatlons  and  changes 
incorporated  without  noticeable  effect  on  the  user- 

DBMS  systems  are  found  on  every  architecture  fonm  the  small  to  the 
very  large.  In  fact,  more  than  one  DBMS  is  found  on  She  full  spectrum 
of  machine  architectures  with  user  transparency  more  real  than  imagined. 
Because  of  this  feature  It  is  quite  possible  now  to  enmsider  as  a  reason¬ 
able  alternative  to  a  single,  centralized,  large  system  supporting  a  DBMS, 
s  spectrum  of  machines  each  supporting  a  local  DBMS  asd  each  In  support 
of  the  other. 

Hi.  THE  ALTERNATIVE  -  DISTRIBUTED  DBMS 


With  continued  growth  in  data  and  processing  requirements  come  the 
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a.  A  Multi-host  System  with  s  Common  Bsckend  Machine 
Supporting  DBMS  Function 


b.  A  Single  Host  System  with  Multiple  Backend  Systems 
Each  Supporting  a  DBMS  system 


Figure  1:  The  Various  Configurations  Involving  a  Data  Base  Function 


c.  A  Multi  Host  Backend  and  Bi-Functional  (Host  Backend 
Combination)  Distributed  Network. 


Figure  1  (Continued):  The  Various  Configurations 
Involving  a  Data  Base  Function 


continual  requirement  for  upgrading  and  increasing  storage  and  processing 
facilities.  As  a  viable  option  to  growth  of  the  single  large  processor, 
the  possibility  exists  that  required  capabilities  can  be  obtained  by 
addition  of  smaller  processors  in  the  fashion  shown  in  Figures  l.a  -  l.c. 
Jtach  figure  portrays  an  increasingly  complex  environment.  Within  the 
three  figures  there  are  three  functional  machine  categories  shown,  and 
these  are  described  in  the  following  paragraphs. 

The  first  is  that  of  a  host.  This  machine  can  be  of  any  size  and 
architecture.  Typically  it. is  a  large  machine  which  serves  the  complete 
variety  of  users.  This  machine  may  also  support  DBMS  activities. 

The  second  machine  category  shown  is  that  of  a  back-end  machine. 

This  machine  can  also  be  any  one  of  a  variety  of  architectures,  although 
typically  it  is  a  minicomputer.  The  purpose  of  this  machine  is  to  support 
some  or  all  of  the  data  base  activity.  A  typical  software  configuration 
for  the  host  and  back-end  is  shown  in  Figure  2.  Essentially,  the  opera¬ 
tion  of  this  configuration  is  a s  follows:  A  host  program  requiring  a 
DBMS  function  executes  a  call  to  the  DBMS  monitor.  This  residual  monitor 
forwards  the  call  to  the  back-end  machine  which  allocates  its  resources 
(if  available)  to  provide  the  requested  service.  In  order  to  satisfy 
the  requested  service,  the  back-end  may  have  to  execute  several  disk 
reads,  along  with  substantial  processing.  Once  the  requested  information 
is  obtained,  it  is  returned  back  to  the  host  monitor  which  makes  it 
available  to  the  requesting  task.  Figure  3  shows  the  relationship 
cocained  by  simulation  between  data  base  requests  oo  a  host  only,  a 
host  and  back-end  where  the  back-end  provides  from  zero  to  five  levels 
of  multi-programming  {1|. 


The  last  machine  category  shown  in  Figure  l.c  is  that  of  a  bi-func- 
tlonal  machine.  In  this  situation  a  machine  is  both  serving  in  the  back- 
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Figure  2:  Software  Distribution  in  a  Host  and  Back-End  System 
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Level  of  Multi -Programming 
in  Back-End 


Figure  3:  Relationship  of  DBMS  Requests 
and  a  Configuration  of  Host  Only  and  Host/Back-End 
Where  the  Back-End  Is  Multi -Programmed  at  Several  Levels 


end  mode  as  well  as  Che  hose  mode.  However,  unlike  the  strictly  host/ 
back-end  function  which  implied  that  machines  be  co-located,  bl-func- 
tlonal  machines  can  provide  the  environment  for  a  distributed  data  base 
system. 

Before  dealing  with  specific  problems  attendant  in  a  distributed 
network.  It  Is  worth  while  to  consider  some  advantages  and  disadvantages 
associated  with  both  centralized  and  decentralized  concepts.  Neither 
option  is  clearly  advantageous  In  all  cases,  and  hence  the  decision  process 
must  be  carefully  considered. 

The  advantages  of  a  centralized  system  are  concerned  with  control, 
protection,  and  redundancy.  With  respect  to  control,  a  central  facility 
can  provide  better  qualified  DBA  personnel  to  control  growth,  development 
and  deployment  of  data.  Another  advantage  is  in  the  area  of  protection. 

It  is  obvious  that  data  collected  in  one  location  can  be  more  easily  pro¬ 
tected  than  data  which  is  distributed.  The  last  area  to  be  mentioned  is 
that  of  redundancy.  All  too  often  the  temptation  exists  to  proliferate 
copies  of  data.  This  proliferation  with  its  attendant  problems  is  best 
controlled  within  a  central  facility. 

The  disadvantages  to  a  single  centralized  system  is  alleviated  by 
the  introduction  of  back-ends  or  local  networks.  However,  if  one  consi¬ 
ders  the  constant  upgrade  problem  which  can  require  from  slight  to  major 
software  modifications  coupled  with  the  ever  increasing  complexity  of 
supplied  equipment  and  software,  then  the  problems  can  be  truly  over¬ 
whelming.  Unfortunately,  although  source  language  standards  exist,  they 
are  almost  always  ignored.  The  last  disadvantage  occurs  in  costs  of  the 
ever  increasing  systems.  For  this  reason,  upgrades  are  often  delayed, 
which  causes  repercussions  in  service  and  growth. 

With  respect  to  decentralized  systems,  the  advantages  lie  in  the 
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areas  of  data  availability,  saaller  physical  machine  requirements ,  and 
a  potential  for  providing  better  service.  Obviously,  If  a  particular 
group  of  users  requires  access  to  a  collection  of  data,  the  data  and  the 
machine  should  be  located  In  proximity  to  those  users.  In  most  cases, 
the  supplied  machine  resources  will  be  smaller,  easier  to  maintain,  service, 
and  use.  Furthermore,  any  required  upgrade  in  facilities  can  be  made  on 
a  local  basis,  not  interfering  with  other  nonrelated  users. 

The  disadvantages  stem  from  a  lack  of  central  control  with  attendant 
growth  in  redundant  data*,  and  the  problems  of  resolving  resultant  data 
descrepancles. 

With  these  considerations  we  then  propose  the  system  as  shown  in 
Figure  4.  Such  a  system  consists  of  machine  groups  (clusters)  tightly 
linked  together  with  high-speed  communication  lines.  It  is  quite  possible 
to  talk  about  the  degenerative  case  where  a  cluster  consists  of  only  a 
single  machine.  In  general,  3  cluster  might  consist  of  multiple  heter¬ 
ogeneous  machines,  each  of  which  may  be  bi-functional  or  dedicated  to  a 
specific  task.  Between  each  cluster  communication  can  take  place  over 
any  standard  communciation  lines  using  any  communication  protocol  desired. 
PROBLEMS  IN  DISTRIBUTED  DATA  BASE  SYSTEMS 

While  distributed  data  base  systems  offer  many  potential  advantages 
(as  discussed  in  the  preceeding  sections),  the  data  base  industry  has  not 
yet  advanced  to  the  point  of  producing  a  commercially  available  package. 
Several  formidable  obstacles  lie  in  the  path  of  a  generalized,  distributed 
DBMS.  A  review  of  these  problems  is  presented  here  along  with  a  discussion 
of  potential  solutions. 

DEADLOCK 


The  phenomenum  of  deadlock  has  long  been  an  important  problem  for 
operating  system  designers.  In  general,  deadlock  occurs  when  a  set  of 
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casks  have  blocked  each  ocher  from  execution  by  requesting  resources 
held  by  other  tasks  In  Che  sec  while  holding  resources  requested  by  other 
tasks.  In  terms  of  data  base  management,  the  resources  are  data  records 
or  areas. 

In  many  situations,  deadlock  can  be  avoided  by  limiting  the  update 
ability  for  a  portion  of  the  data  base  to  a  single  task.  This  is  not  an 
attractive  approach  for  distributed  systems,  since  one  of  the  motivating 
factors  for  a  distributed  DBMS  is  the  sharing  of  data.  If  shared  update 
Is  permitted  in  a  DBMS,  'then  the  potential  for  deadlock  exists.  Deadlock 
may  be  handled  by  either  detecting  its  existence  and  then  resolving  the 
conflict  or  by  preventing  all  possible  deadlock  occurrences.  Most  existing 
single  machine  systems  use  deadlock  detection  and  rollback  as  their  means 
of  treating  the  deadlock  problem. 

In  a  distributed  DBMS,  the  most  costly  operation  is  intermachine 
communication.  Therefore,  the  amount  of  intermachine  communication  be¬ 
comes  the  dominant  factor  when  evaluating  the  performance  of  deadlock 
detection  and  deadlock  prevention  schemes  for  distributed  data  bases. 
Deadlock  prevention  in  a  distributed  DBMS  requires  that  each  task  be 
Informed  as  to  which  records  that  it  may  access  are  shared.  For  this 
information  to  be  meaningful,  only  the  records  shared  with  currently  active 
tasks  should  be  Included.  This  implies  that  whenever  a  task  that  updates 
shared  records  is  activated,  it  must  send  a  message  to  all  other  casks. 

When  this  has  taken  place,  the  new  task  can  proceed.  Whenever  a  need  to 
access  a  shared  record  arises ,  a  prevention  algorithm  can  be  Invoked  to 
determine  if  the  access  may  proceed.  If  not,  the  task  is  blocked  until 
the  resources  are  available. 

Deadlock  detection  in  a  distributed  DBMS  Involves  first  identifying 
a  set  of  two  or  more  tasks  blocking  each  other  from  a  collection  of  shared 
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records.  Once  the  set  of  conflicting  resources  are  identified,  one  of  the 
casks  must  be  rolled  back  to  some  point  that  will  free  the  resources 
necessary  to  break  the  deadlock. 

It  is  difficult  to  projecC  Che  performance  effects  of  deadlock 
•detection  and  prevention  in  a  distributed  DBMS.  A  prevention  scheme 
will  block  tasks  in  some  situations  in  which  no  deadlock  would  actually 
occur.  Detection  takes  no  unnecessary  actions  in  this  respect.  However, 
as  Indicated  in  the  next  subsection,  rollback  in  a  distributed  DBMS 
could  cause  substantial  pesformance  degradation. 

IV.?..  ROLLBACK  A.VD  RECOVERY 

Since  all  data  base  systems  are  susceptible  to  both  hardware  and 
software  failure,  recovery  procedures  are  necessary  to  insure  the 
integrity  of  the  data  base  and  to  minimize  the  effect  of  system  failures. 
Recovery  procedures  are  similar  to  those  for  handling  deadlock  in  that 
they  become  increasingly  complex  as  the  data  base  becomes  more  integrated. 
The  major  difficulty  in  data  base  recovery  is  that  an  erroneous  application 
task  may  produce  incorrect  data  which  then  may  be  accessed  by  other  tasks. 
If  not  handled  properly  the  bad  data  may  have  a  cascading  effect  throughout 
the  data  base  and  thus  damage  its  integrity  as  shown  in  Figure  5. 

There  are  two  extreme  approaches  to  DBMS  recovery  for  an  application 
program  failure.  Some  systems  rollback  only  the  terminated  program  while 
others  rollback  the  entire  data  base  to  the  point  of  initiation  of  the 
offending  task.  The  former  approach  does  not  effect  tasks  which  have  no 
access  to  the  polluted  data  although  it  may  permit  Incorrect  data  to 
have  been  used  by  other  application  task.  The  latter  approach  is  more 
conservative  since  it  insures  correct  data  at  the  cost  of  potentially 
rolling  back  tasks  which  did  not  interact  with  the  polluted  data. 

Selective  recovery  is  an  intermediate  recovery  strategy  which 
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entails  rolling  back  only  those  tasks  that  are  operating  with  polluted 
data.  Overall  system  throughput  and  data  base  access  would  both  increase 
under  a  selective  recovery  strategy.  In  order  for  a  selective  scheme  to 
be  worthwhile,  data  base  integrity  must  be  maintained.  Therefore,  the 
scheme  must  be  certain  of  Including  all  tasks  chat  have  used  incorrect 
*  data  in  the  recovery  process.  In  order  to  accomplish  selective  rollback, 
information  on  the  Interaction  between  tasks  must  be  maintained.  The 
Interaction  information  would  take  the  form  of  a  potential  shared  data 
list  which  can  be  computed  from  the  sub-scher.as  of  the  application  tasks 
prior  to  execution.  Communication  must  be  limited  to  one  transmission 
to  each  back-end  processor  per  rollback  operation  if  performance  is  not 
to  be  effected.  Maryanski  and  Fisher  [2]  have  developed  a  selective 
recovery  scheme  for  distributed  data  base  systems. 

1V.3.  DATA  CONVERSION 

The  conversion  of  data  is  one  problem  that  is  unique  to  distributed 
data  base  systems.  The  conversion  problem  has  two  aspects:  the  physical 
translation  of  the  data  and  the  logical  conversion  of  the  data  base 
structure.  The  need  for  physicc’.  conversion  arises  when  processors  with 
different  internal  codes  reside  In  the  data  base  network.  The  code 
conversion  problem  is  not  difficult  for  any  pair  of  machines.  However, 
if  distinct  machines  reside  in  the  network,  then  it  would  be  necessary 
for  each  processor  node  to  contain  K-l  translation  routines.  An  alter¬ 
native  approach  is  to  define  a  network  standard  cade  which  is  used  in 
all  intermachine  commune iat ion.  This  method  results  in  a  maximum  of  2 
translation  routines  per  machine. 

The  most  significant  effort  aimed  at  a  generalised  translation 
scheme  for  data  bases  is  the  University  of  Michigan  Data  Translation 
Project  (3-Sl.  Under  this  approach,  all  data  bases  are  described  using 
a  universal  Stored  Data  Definition  Language.  The  translations  are  driven 


15 


by  Cables  produced  by  compilers  for  the  SDDL  and  the  Translation  Defini¬ 
tion  Language  (TDL) .  The  TDL  Is  employed  to  express  the  relationship 
between  the  source  and  target  data  bases.  This  translation  methodology 
requires  only  one  translation  program  at  each  DBMS  node.  However,  the 
translator  must  be  supplemented  with  a  SDDL  Table  and  (K-l)  TDL  Tables. 

IV. U.  OPERATINC  SYSTEMS 

A  DBMS  on  a  single  computer  relies  upon  the  operating  system  of  the 
computer  to  perform  functions  such  as  I/O  and  task  management.  When  the 
DBMS  system  software  Is  distributed  over  a  network  its  relationship  with 
Che  operating  systems  of  the  network  nodes  Is  altered. 

Several  forms  of  operating  systems  may  be  applicable  In  a  distributed 
DBMS.  The  nose  straightforward  approach  Is  to  maintain  a  completely  gen¬ 
eral  purpose  operating  system  on  each  processor.  However,  if  primary 
memory  la  a  critical  resource  oa  a  processor.  It  may  be  desireable  to 
employ  a  reduced  version  of  the  operating  system.  Since  the  DBMS  software 
la  distributed  functionally  between  host  and  back-end  processors,  it  may 
be  desireable  to  distribute  operating  system  functions  in  a  similar  manner. 
For  Instance,  since  the  host  machine  does  not  perform  any  data  base  I/O 
operations,  the  appropriate  drivers  could  be  removed  from  that  machine's 
operating  system.  The  concept  of  subsetting  general  purpose  operating 
systems  can  be  extended  to  developing  of  a  specially  tailored  operating 
system  for  data  base  machines  [6].  Tailored  operating  systems  are  parti¬ 
cularly  well  suited  for  hardware  and  stand  alone  data  base  machines  (7-9). 

1V.5.  COMMUNICATIONS 

If  a  distributed  DBMS  is  to  provide  acceptable  performance,  lnter- 
machlne  communication  must  be  carried  out  efficiently.  In  addition,  the 
communication  process  should  be  transparent  to  the  application  programmer. 


These  requirements  ran  be  satisfied  by  a  standardized,  portable 
communications  Interface  that  completely  relieves  the  DBMS  of  any 
communication  functions.  Portability  is  an  Important  factor  if  the 
network  is  to  expand.  'It  is  highly  desireable  to  have  a  standard 
communication  system  that  can  easily  be  implemented  upon  a  new  archi¬ 
tecture.  If  portability  is  a  requirement,  implementation  of  the 
communication  (and  data  base)  software  should  be  in  a  common  high  order 
language.,  Descriptions  of  communication  Interfaces  for  data  base  systems 
built  upon  networks  can  be  found  in  References  [9-10]. 

IV. 6.  INTEGRITY 

The  distribution  of  a  data  base  complicates  the  chore  of  maintaining 
the  data  base  integrity.  However,  under  certain  circumstances,  a  distri¬ 
buted  DBMS  provides  greater  security  than  a  single  machine  system.  In 
a  geographically  distributed  DBMS  the  involvement  of  additional  compu¬ 
tation  and  communication  components  increases  the  probability  of  a  hard¬ 
ware  failure.  On  the  other  hand,  the  cooanunications  software  provides  a 
means  of  checking  the  status  of  lines  and  processors  and  thus  identifying 
a  failure  more  rapidly  than  in  the  case  of  a  single  processor  DBMS. 

A  DBMS  with  a  dedicated  back-end  processor  can  be  made  more  secure 
than  a  DBMS  on  a  single,  general  purpose  machine.  The  reason  for  increased 
security  is  that  no  unauthorized  programs  can  be  executed  on  the  back-end 
machine  since  it  is  limited  to  the  execution  of  data  base  commands.  If  the 
communications  lines  can  be  secured  (not  an  easy  task).  Then  the  monitoring 
of  data  base  activity  can  be  prevented. 

IV. 7.  REDUNDANCY 

In  a  well  designed,  integrated  data  base,  data  redundancy  should  be 
quite  rare.  However,  if  the  data  base  is  to  be  distributed  geographically, 


It  may  become  deslreable  from  a  performance  standpoint  to  maintain 
redundant  copies  of  data  at  various  locations.  Naturally,  the  update 
frequency  of  redundant  data  should  be  quite  low.  However,  the  updating 
of  redundant  data  in  a  distributed  DBMS  produces  considerable  overhead 
since  multiple  data  base  operations  must  be  generated. 

Redundant  data  in  a  distributed  DBMS  becomes  most  troublesome  when 
a  recovery  operation  involves  modified  redundant  data.  The  tasks  of 
determining  the  effect  on  other  programs  and  data  of  multiple  copies 
of  Incorrect  data  items  can  become  quite  complex  in  even  a  moderately 
integrated  distributed  DBMS.  Since  the  update  of  redundant  data  can 
not  be  performed  at  precisely  the  same  moment  at  all  nodes  of  the 
network,  sequencing  of  the  updates  is  also  a  problem  for  the  recovery 
procedure. 

At  the  present  time,  a  recovery  procedure  for  a  distributed  DBMS 
which  can  handle  redundant  data  has  not  yet  been  proposed. 
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CON'CLliSION 

Because  of  increasingly  complex  systems  and  supporting  software  of 
minicomputers  and  their  relatively  low  cost, much  attention  has  been 
given  to  minicomputer  networks  or  minicomputers  in  support  of  larger 
systems.  With  this  interest  it  is  Important  to  consider  that  achieving 
data  distribution  over  heterogeneous  machines  and  systems  is  not  a  sim¬ 
ple  task.  However,  several  developments  are  underway  at  multiple  loca¬ 
tions  to  provide  such  a  facility  which  is  independent  of  the  hardware. 

The  considerations  in  this  paper  are  alternatives  and  problems  which 
we  have  faced  in  designed  and  lmpllmenting  a  distributed  system.  Thus, 
the  purpose  of  this  paper  is  to  enumerate  and  identify  problems  which 
must  be  solved  when  designing  a  network  of  machines  and  the  attendant 
software  for  implementing  a  distributed  data  base  management  system. 
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